Claim Amendments 



1 . (Currently Amended) A method comprising: 

using, by one or more computing devices, a system definition model in a 
development phase of a system to design the system, the system definition model 
including one or more requirements of the system that must be satisfied by an 
environment of which the system is to be deployed in order for the system to run in the 
environment, wherein the system is an application , wh e r ei n th e us i ng compr i s e s 
i nc l ud i ng, i n tho system def i n i t i on model, constra i nts that must bo sat i sf i ed by an 
e nv i ronm e nt i n ord e r for th e syst e m to b e run in th e e nv i ronm e nt ; 

subsequently using, by the one or more computing devices, the system definition 
model in a deployment phase of the system to deploy the system on at least one of the 
one or more computing devices; 

after deployment of the system, calling, by the one or more computing devices, 
one or more functions defined within the system definition model during a management 
phase of the system to manage the system deployed on the at least one of the one or 
more computing devices; and 

validating the environment , by the one or more computing devices, by comparing 
the one or more requirements of the system with the environment of which the system is 
to be deployed to determine whether the one or more requirements of the system are 
satisfied by the environment that th e constraints ar e sat i sf ie d during at least the design 
of the system. 

2. (Canceled) 
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3. (Canceled) 



4. (Original) A method as recited in claim 1 , further comprising: 

using knowledge obtained during management of the system to design a 
subsequent version of the system. 

5. (Original) A method as recited in claim 1, wherein the system definition 
model includes knowledge describing how to deploy the system on the one or more 
computing devices. 

6. (Original) A method as recited in claim 1, wherein the system definition 
model includes knowledge describing how to deploy the system on multiple different 
computing devices, and wherein the knowledge includes different knowledge describing 
how to deploy the system on each of the multiple different computing devices. 

7. (Canceled) 

8. (Currently Amended) A method as recited in claim 1, further comprising 
validating the system by comparing one or more requirements of the environment with 
the system to determine whether the one or more requirements of the environment are 
satisfied by the system during at least the w h e r ei n th e syst e m d e f i n i t i on mod el can b e 
us e d to ch e ck wh e th e r th e constra i nts are sat i sf ie d by th e on e or mor e comput i ng 
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d e v i c e s dur i ng design of the system. 



9. (Currently Amended) A method as recited in claim 1, wherein the 
validating the environment compares the one or more requirements of the system with 
the environment during both a system d e f i n i t i on mod el can b e us e d to ch e ck wh e th e r 



system prior to the using the system definition model to deploy the system and during a 
management of the system. 

10. (Original) A method as recited in claim 1, wherein the system definition 
model includes knowledge describing how to manage the system after deployment of 
the system. 

1 1 . (Original) A method as recited in claim 1 , further comprising: 

during management of the system, using a flow to automatically propagate a 
configuration change to the system. 

12. (Canceled) 

13. (Previously Presented) A method as recited in claim 48, wherein the 
system definition model for the environment is derived through examination of the 
configuration of the one or more computing devices. 
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14. (Canceled) 



15. (Original) A method as recited in claim 1, wherein a plurality of 
environments are deployed on the one or more computing devices, the method further 
comprising: 

using a plurality of different system definition models to design each of the 
plurality of environments, wherein each of the plurality of environments is associated 
with one of the plurality of different system definition models; 

using, for each environment, the associated one of the plurality of different 
system definition models to deploy the environment; and 

after deployment, using, for each environment, the associated one of the plurality 
of different system definition models to manage the environment. 

16. (Original) A method as recited in claim 15, wherein each of the plurality of 
environments is layered, and wherein each of the plurality of environments serves as 
environment to one other of the plurality of environments or to the system. 

17. (Currently Amended) One or more computer readable storage media 
having stored thereon a plurality of instructions that when executed by a processor, 
cause the processor to: 

use a system definition model in a development phase of a system to design the 
system, wherein the system is an application, the system definition model includes a 
representation of an environment in which the application is to be deployed, and the 
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using includes binding the application to the representation in the system definition 
model, the representation including definitions for hosts of the environment of their 
application components and constraints on the configuration of their applications; 

determine that the environment in which the application is to be deployed 
satisfies the constraints on the configuration of their applications prior to deploying the 
system; 

subsequently use the system definition model in a deployment phase of the 
system to deploy the system on one or more computing devices; and 

after deployment of the system, invoking one or more functions defined within the 
system definition model in a management phase of the system to manage the system 
deployed on the one or more computing devices. 

18. (Canceled) 

19. (Canceled) 

20. (Previously Presented) One or more computer readable storage media 
as recited in claim 17, wherein the system definition model includes knowledge 
describing how to deploy the system. 

21. (Previously Presented) One or more computer readable storage media 
as recited in claim 17, wherein the system definition model includes knowledge 
describing how to deploy the system in multiple different environments, and wherein the 
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knowledge includes different knowledge describing how to deploy the system in each of 
the multiple different environments. 



22. (Previously Presented) One or more computer readable storage media 
as recited in claim 17, wherein the system definition model includes constraints that 
must be satisfied by an environment in order for the system to be run in the 
environment. 

23. (Previously Presented) One or more computer readable storage media 
as recited in claim 22, wherein to use the system definition model to deploy the system 
is to use the system definition model to check whether the constraints are satisfied by 
the environment during design of the system. 

24. (Previously Presented) One or more computer readable storage media 
as recited in claim 17, wherein the system definition model includes knowledge 
describing how to manage the system. 

25. (Currently Amended) An apparatus comprising: 
a processor; 

means operable by the processor for using a system definition model in a 
development phase of a system to design the system, wherein the system is an 
application, wherein the using comprises including, in the system definition model, 
requirements of the system constra i nts that must be satisfied by an environment in 
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order for the system to be run in the environment; 

means operable by the processor for subsequently using the system definition 
model in a deployment phase of the system to deploy the system on one or more 
computing devices; 

means operable by the processor for, after deployment of the system, calling one 
or more functions defined in the system definition model in a management phase of the 
system to manage the system deployed on the one or more computing devices; and 

means operable by the processor for validating the environment by comparing 
the requirements of the system with the environment to determine whether the 
requirements of the system are satisfied by the environment that th e constra i nts ar e 
sat i sf ie d during at least the design of the system prior to the using the system definition 
model to deploy the system . 

26. (Previously Presented) An apparatus as recited in claim 25, wherein the 
means for subsequently using the system definition model in a development phase 
comprises means for including, in the system definition model, knowledge describing 
how to deploy the system. 

27. (Previously Presented) An apparatus as recited in claim 25, wherein the 
means for subsequently using the system definition model in a development phase 
comprises means for including, in the system definition model, knowledge describing 
how to deploy the system in multiple different environments, and wherein the knowledge 
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includes different knowledge describing how to deploy the system in each of the 
multiple different environments. 



28. (Canceled) 

29. (Canceled) 

30. (Previously Presented) An apparatus as recited in claim 25, wherein the 
means for using the system definition model in a management phase of the system 
comprises means for including, in the system definition model, knowledge describing 
how to manage the system. 

31 . (Currently Amended) A system comprising: 
a processor; and 

a plurality of executable instructions which, when executed by the processor, 
perform operations comprising: 

using a system definition model to design an application, the system 
definition model being applicable across a lifecycle of the application, wherein the 
lifecycle of the application includes design of the application, deployment of the 
application, and management of the application, and wherein the system 
definition model includes a representation of an environment in which the 
application is to be deployed, and the using includes binding the application to 
the representation in the system definition model, the system definition model 
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r e pr e s e ntat i on including d e f i n i t i ons for hosts of th e e nv i ronm e nt of th ei r 
app li cat i on compon e nts and requirements of the application that must be 
satisfied by the environment in order for the application to run in the environment 
constra i nts on th e conf i gurat i on of th e ir app li cat i ons ; 

subsequently using the system definition model to deploy the application 
on one or more computing devices; m4 

after deployment of the application, calling one or more functions defined 
within the system definition model to manage the application deployed on the 
one or more computing devices; 

wherein the system further includes a schema to dictate how functional 
operations within the system definition model are to be specified. 

32. (Original) A system as recited in claim 31, wherein the system definition 
model includes information describing how to deploy the application. 

33. (Original) A system as recited in claim 31, wherein the system definition 
model includes information describing how to deploy the application in multiple different 
environments, and wherein the information includes different information describing how 
to deploy the application in each of the multiple different environments. 

34. (Currently Amended) A system as recited in claim 31, wherein the 
system definition model further includes requirements of the environment constra i nts 
that must be satisfied by the application e nv i ronm e nt in order for the application to be 
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run in the environment , the plurality of executable instructions to further perform 
operations comprising using the requirements of the environment during runtime while 



the application is being managed to validate the changes to the application during 



runtime . 



35. (Currently Amended) A system as recited in claim 34, wherein the 
plurality of executable instructions to further perform operations comprising validating 
the environment by comparing the requirements of the application with the environment 
to determine whether the requirements are satisfied by the environment during at least 
the syst e m d e f i n i t i on mod el can b e us e d to ch e ck wh e th e r th e constra i nts ar e sat i sf ie d 
by on e or mor e comput i ng d e v i c e s i n th e system dur i ng design of the application-afid 
dur i ng manag e m e nt of th e app li cat i on . 

36. (Currently Amended) A system as recited in claim 35[[34]], wherein the 
plurality of executable instructions to further perform operations comprising validating 
the application by comparing the requirements of the environment with the application to 
determine whether the requirements of the environment are satisfied by the application 
during at least the syst e m d e f i n i t i on model can b e us e d to ch e ck wh e th e r th e 
constra i nts ar e sat i sf ie d by th e e nv i ronm e nt dur i ng design of the application. 

37. (Original) A system as recited in claim 31, wherein the system definition 
model includes information describing how to manage the application. 
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38. (Previously Presented) A system as recited in claim 31, wherein the 
system further comprises: 

another system definition model applicable across a lifecycle of the environment, 
wherein the lifecycle of the environment includes design of the environment, 
deployment of the environment, and management of the environment; and 

wherein the schema is further to dictate how functional operations within the 
other system definition model are to be specified. 

39. (Previously Presented) A system as recited in claim 38, wherein the 
other system definition model for the environment is derived through examination of the 
configuration of one or more computing devices. 

40. (Currently Amended) A system as recited in claim 38, wherein the 
system definition model includes constraints that must be satisfied by the environment 
in order for the application to be run on the environment, and wherein the other system 
definition model includes etr4er-constraints that must be satisfied by the application in 
order for the application to be run on the environment. 

41. (Original) A system as recited in claim 38, wherein the system further 
comprises: 

an additional system definition model applicable across a lifecycle of an 
additional environment, wherein the lifecycle of the additional environment includes 
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design of the additional environment, deployment of the additional environment, and 

management of the additional environment; 

wherein the additional environment is layered below the environment; and 
wherein the schema is further to dictate how functional operations within the 

additional system definition model are to be specified. 

42. (Canceled) 

43. (Canceled) 

44. (Previously Presented) A method as recited in claim 1, wherein the 
system definition model includes information describing how to deploy the system in 
multiple different runtimes, and wherein the information includes different information 
describing how to deploy the system in each of the multiple different runtimes. 

45. -47. (Canceled) 

48. (Currently Amended) A method as recited in claim 1, further comprising, 
prior to the design, deployment, and management of the system, 

using, by the one or more computing devices, another system definition model to 
design the environment, wherein the system is deployed to the environment on the one 
or more computing devices; 

subsequently using, by the one or more computing devices, the other system 
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definition model to deploy the environment on the one or more computing devices; and 
after deployment of the environment, using, by the one or more computing 

devices, the other system definition model to manage the environment deployed on the 

one or more computing devices, 

wherein the system definition model includes constra i nts the one or more 

requirements of the system that must be satisfied by the environment in order for the 

system to be run on the one or more computing devices, and wherein the other system 

definition model includes othe^constraints that must be satisfied by the system in order 

for the system to be run on the one or more computing devices 
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